tg-me.com/php_interview_lib/721
Last Update:
Чем PDO::FETCH_ASSOC отличается от PDO::FETCH_OBJ на низком уровне?
В PDO существуют различные режимы выборки данных, определяемые константами, такими как PDO::FETCH_ASSOC
и PDO::FETCH_OBJ
. Они влияют на то, в каком формате будет возвращена строка из результирующего набора при выполнении запроса.
PDO::FETCH_ASSOC: При использовании этого режима каждая строка возвращается в виде ассоциативного массива, где ключами являются названия столбцов. Это позволяет обращаться к значениям столбцов по их именам.
PDO::FETCH_OBJ: В этом режиме каждая строка возвращается как объект анонимного класса, где свойства соответствуют названиям столбцов. Доступ к данным осуществляется через свойства объекта.
Низкоуровневые различия:
На низком уровне основное различие между этими режимами заключается в типе возвращаемой структуры данных:
🔸 PDO::FETCH_ASSOC
: возвращает ассоциативный массив (array
), где ключами являются строки (имена столбцов), а значениями — соответствующие данные.
Habr
🔸 PDO::FETCH_OBJ
: возвращает объект (object
) стандартного класса (stdClass
), где свойства объекта соответствуют именам столбцов.
Выбор между этими режимами зависит от предпочтений разработчика и специфики задачи. Если удобнее работать с массивами и использовать синтаксис $row['column_name']
, то подойдет PDO::FETCH_ASSOC. Если предпочтительнее объектный доступ через $row->column_name
, то стоит использовать PDO::FETCH_OBJ.
Важно отметить, что при использовании PDO::FETCH_OBJ создается новый экземпляр объекта для каждой строки результирующего набора, что может потреблять больше памяти по сравнению с ассоциативными массивами. Однако это различие обычно незначительно и становится заметным только при обработке больших объемов данных.
BY Библиотека собеса по PHP | вопросы с собеседований
Warning: Undefined variable $i in /var/www/tg-me/post.php on line 283
Share with your friend now:
tg-me.com/php_interview_lib/721